草庐IT

TypeScript 运算符

全部标签

c++ - 函数定义上的全局命名空间作用域运算符

我正在围绕C++库创建C包装器。执行此操作时常犯的一个错误是函数声明和定义由于某种原因(拼写错误、重命名、添加/删除参数等)不匹配。例如://enabledata.hMDS_C_APIconstchar*motek_mds_enable_data_get_enable_command_name();//enabledata.cppconstchar*motek_mds_enable_data_enable_command_name(){...}名称不匹配,但由于缺少这些函数的作用域,因此不会导致任何编译错误,只会在稍后以链接错误的形式出现。我希望编译器通过使用全局作用域运算符来帮助我找

C++:我可以做一个赋值运算符 "explicit"吗

我的任务是迁移C++类库中的错误处理概念。以前简单返回bool(成功/失败)的方法应修改为返回一个Result对象,该对象传达机器可读的错误代码和人类可读的解释(以及更多在这里无关紧要的内容)。遍历数千行代码很容易出错,因此我尝试从编译器获得对此任务的最佳支持。我的结果类在其他成员方法中有一个从代码构造结果的构造函数和代码的赋值运算符:classResult{public:typedefunsignedlongResultCode;explicitResult(ResultCodecode);//(1)Result&operator=(ResultCodecode);//(2)};备注

c++ - **有符号**正整数的一元减运算符何时会导致溢出?

通常,INT_MIN是-2^n而INT_MAX是2^n-1是否可以保证,如果x是positive类型的int则expressoin-x没有不会导致溢出? 最佳答案 它是隐式保证的,因为它对所有允许的签名形式都是正确的:(以16位int为例)1的补码,INT_MIN=-32767,INT_MAX=32767二进制补码,INT_MIN=-32768,INT_MAX=32767符号和大小,INT_MIN=-32767,INT_MAX=32767不允许使用其他形式。正如我们所见,对于所有允许的形式,abs(INT_MIN)>=abs(INT

c++ - 重载多个运算符

简而言之,我的目标是让foo[bar]返回type1,并且foo[bar]=返回type2。我正在用C++编写一个对象,它进展顺利,但是只有一件我想做的小事,但这似乎是不可能的。我的对象是一个存储类,所以我使用数组下标来访问值。我还需要赋值,所以我也重载了=运算符。但是,这有点不方便,因为我的类保存的值是第一类对象,所以对于我的数组下标重载,我不能按原样返回它们。我必须返回一个中间类来处理=运算符,但我还想在不进行额外输入的情况下检索值。有什么办法吗?骇人听闻的方式是可以接受的。编辑:这是它(应该)做什么的一个例子#include#includeclassfoo{char*a[100]

c++ - 为什么在 boost python vector 索引套件中需要比较运算符?

我想用公开C++代码std::vector到python。我的classA{};没有实现比较运算符。当我尝试BOOST_PYTHON_MODULE(libmyvec){usingnamespaceboost::python;class_("A");class_>("Avec").def(boost::python::vector_indexing_suite>());}我收到有关比较运算符的错误。如果我将A的定义更改为classA{public:booloperator==(constA&other){returnfalse;}booloperator!=(constA&other){

具有从模板多重继承的 C++ 重载运算符

我有一个表示HTTP客户端某些部分的层次结构,如下所示:typedeflist>KeyVal;structHeader{stringname;stringvalue;...};structParam{stringname;stringvalue;...};/*Somethingthatcontainsheaders*/templateclassWithHeaders{KeyValheaders;public:virtualT&operator(h.name,h.value));returnstatic_cast(*this);}};/*Somethingthatcontainsquer

c++ - 在 C++ 中重载不同类型的比较运算符

我需要能够将我的一个类(它包含的不仅仅是一个整数)与整数进行比较,即使这可能会稍微扩展相等性,但它已经足够接近了......如何为不同类型重载相等运算符?我基本上有这样一个类structMyClass{intstart;intmiddle;intthreequarters;};和重载运算符inlinebooloperator==(constMyClass&lhs,constMyClass&rhs){returnlhs.middle==rhs.middle;}因此,当与整数进行比较时,我也需要与中间变量进行比较,但我不确定是否需要两组运算符函数,一组是lhs的整数,另一组是rhs的整数?

c++ - 当复制 elison 失败时,有没有办法阻止移动构造函数后跟移动赋值运算符?

我有一种情况,我想用一个参数调用一个函数,并将结果返回到同一个参数中foo=f(foo);另外,我假设参数x很大,所以我不想调用它的复制构造函数,而是调用它的移动构造函数。最后,我不想通过引用传递参数,因为我想将函数f与另一个函数g组合在一起。因此,这样的事情foo=g(f(foo));有可能。现在,有了移动语义,这一切几乎都是可能的,如下面的程序所示#includestructFoo{Foo(){std::cout这个程序的输出是:constructorCalledfmovemoveassignmentdestructorFinishedwithf(foo)CalledfmoveCa

c++ - 为什么我不能将此运算符重载放在与结构相同的 namespace 中?

我有以下代码:#include#includenamespaceX{std::ostream&operator&v){for(inti=0;ix;};std::ostream&operatorv(10,0);std::cout第一个重载有效,但第二个无效。由于某种原因,它找不到第一个。我收到错误:nomatchfor'operator}'and'conststd::vector')os我不明白为什么会出现此错误。例如,这样的事情似乎是完全有效的:namespaceA{voidfoo(){}namespaceB{voidbar(){foo();}}}但是,解决上述问题的唯一方法是将第二个

c++ - 使用折叠表达式为数组实现 less 运算符

我正在使用最新的clang++在c++17中使用折叠表达式。我尝试使用它为数组实现less运算符,我想将其用于固定大小的字符串。这是我到达的地方。有没有更好的方法来做到这一点,尤其是避免在表达式中分配索引?使用“clang++test_fold_expr_less.cpp-otest_fold_expr_less-std=c++1z”编译它,输出在这里。prompt$./test_fold_expr_less===less===010010000111#include#includestd::uint64_tarr1[8]={1,7,2,4,8,9,3,6};std::uint64_t